/*微信分享*/
var wxshare = {
  isready: false,
  getTicket: function(data, callback, cancelFn, opts){
    // data：后台返回的appid等；callback：成功回调；cancelFn：取消回调；opts：其他参数，如分享所需的title等
    wxshare.wxReady(data, callback, cancelFn, opts)
    wxshare.wxConfig(data, opts)
    //定时请求，防止注册失败
    //土是土了点，管用啊
    var timer = setInterval(function(){
      if(wxshare.isready){
        clearInterval(timer)
        return
      }
      wxshare.wxConfig(data, opts)
    }, 200)
  },

  wxConfig: function(data, opts){
    let jsApiList = []
    if (opts.wxpay) {
      jsApiList.push('chooseWXPay')
    } else {
      jsApiList.push('onMenuShareTimeline')
    }
    wx.config({
      // debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来，若要查看传入的参数，可以在pc端打开，参数信息会通过log打出，仅在pc端时才会打印。
      appId: data.appid || data.appId, // 必填，公众号的唯一标识
      timestamp: data.timeStamp,
      nonceStr: data.nonce_str || data.nonceStr,
      signature: data.signature,
      jsApiList: jsApiList // 必填，需要使用的JS接口列表，所有JS接口列表见附录2
    });
  },

  wxReady: function(data, callback, cancelFn, opts){
    wx.ready(function(){
      wxshare.isready = true
      // 微信支付
      if (opts.wxpay) {
        wx.chooseWXPay({
          timestamp: data.timeStamp, // 支付签名时间戳，注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
          nonceStr: data.nonce_str, // 支付签名随机串，不长于 32 位
          package: 'prepay_id=' + data.prepay_id, // 统一支付接口返回的prepay_id参数值，提交格式如：prepay_id=\*\*\*）
          signType: 'MD5', // 签名方式，默认为'SHA1'，使用新版支付需传入'MD5'
          paySign: data.paySign, // 支付签名
          success: function (res) {
            callback()
          },
          cancel: function(res){  
            //支付取消
            cancelFn()
          }, 
        })
      } else {
        // 未知分享与支付是否会冲突，支付的配置单独处理
        // 分享到朋友圈
        wx.onMenuShareTimeline({
          title: opts.title, // 分享标题
          link: opts.link, // 分享链接，该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
          imgUrl: opts.imgUrl, // 分享图标
          success: function () {
            // 用户确认分享后执行的回调函数
            callback()
          },
          cancel: function () {
            // 用户取消分享后执行的回调函数
            cancelFn()
          }
        })
      }
    })
    wx.error(function(res){
      wxshare.isready = true
    })
  }
}
module.exports = wxshare